<template>
  <el-row type="flex" justify="space-between" align="middle" style="height: 40px;  width: 100%;">
    <el-col :span="20">
      <span>{{ nodeData.name }}</span>
    </el-col>
    <el-col :span="4">
      <el-row type="flex">
        <!-- 两个内容 -->
        <el-col :span="12">{{ nodeData.manager }}</el-col>
        <el-col :span="12">
          <!-- 下拉菜单 element -->
          <el-dropdown @command="handleCommand">
            <span>
              操作<i class="el-icon-arrow-down" />
            </span>
            <!-- 下拉菜单 -->
            <el-dropdown-menu slot="dropdown">
              <el-dropdown-item command="add">添加子部门</el-dropdown-item>
              <el-dropdown-item v-if="!isRoot" command="edit">编辑部门</el-dropdown-item>
              <el-dropdown-item v-if="!isRoot" command="del">删除部门</el-dropdown-item>
            </el-dropdown-menu>
          </el-dropdown>
        </el-col>
      </el-row>
    </el-col>
  </el-row>
</template>

<script>
import { reqDelDepartment } from '@/api/departments'
export default {
  name: 'TrreTools',
  props: {
    nodeData: {
      required: true,
      type: Object
    },
    isRoot: {
      default: false,
      type: Boolean
    }
  },
  methods: {
    async  handleCommand(type) {
      // 删除
      if (type === 'del') {
        const res1 = await this.$confirm('确定删除吗?', '提示').catch(error => error)
        if (res1 !== 'confirm') return
        const res = await reqDelDepartment(this.nodeData.id)
        this.$message.success(res.message)
        this.$emit('del-detps')// 通知父组件重新调用函数渲染页面
      }
      // 添加部门
      if (type === 'add') {
        // 此时传过去的this.nodeData当父级使用
        this.$emit('add-detps', this.nodeData)
      }

      // 编辑
      if (type === 'edit') {
        // 此时传过去的this.nodeData自身使用
        this.$emit('edit-detps', this.nodeData)
      }
    }
  }
}
</script>

<style>
</style>
